<template>
  <a-row :gutter="24">
    <a-col :md="24">
      <a-card :style="cardStyle" :bordered="false">
        <!-- 查询区域 -->
        <div class="table-page-search-wrapper">
          <!-- 搜索区域 -->
          <a-form layout="inline" @keyup.enter.native="searchQuery">
            <a-row :gutter="24">
              <a-col :md="6" :sm="24">
                <a-form-item :label="$t('manuManagement.documentNo')" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input :placeholder="$t('manuManagement.pleaseEnterTheDocumentNumber')"
                    v-model="queryParam.number"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item :label="$t('manuManagement.productInformation')" :labelCol="labelCol"
                  :wrapperCol="wrapperCol">
                  <a-input :placeholder="$t('manuManagement.pleaseEnterBarcodeNameSpecificationAndModel')"
                    v-model="queryParam.materialParam"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item :label="$t('manuManagement.documentDate')" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-range-picker style="width:100%" v-model="queryParam.createTimeRange" format="YYYY-MM-DD"
                    :placeholder="[$t('manuManagement.startTime'), $t('manuManagement.endTime')]" @change="onDateChange"
                    @ok="onDateOk" />
                </a-form-item>
              </a-col>
              <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
                <a-col :md="6" :sm="24">
                  <a-button type="primary" @click="searchQuery">{{ $t('manuManagement.query') }}</a-button>
                  <a-button style="margin-left: 8px" @click="searchReset">{{ $t('manuManagement.reset') }}</a-button>
                  <a @click="handleToggleSearch" style="margin-left: 8px">
                    {{ toggleSearchStatus ? $t('manuManagement.putAway') : $t('manuManagement.open') }}
                    <a-icon :type="toggleSearchStatus ? 'up' : 'down'" />
                  </a>
                </a-col>
              </span>
              <template v-if="toggleSearchStatus">
                <a-col :md="6" :sm="24">
                  <a-form-item :label="$t('setailManagement.warehouseName')" :labelCol="labelCol"
                    :wrapperCol="wrapperCol">
                    <a-select :placeholder="$t('setailManagement.pleaseWarehouse')" showSearch
                      optionFilterProp="children" v-model="queryParam.depotId">
                      <a-select-option v-for="(depot, index) in depotList" :value="depot.id">
                        {{ depot.depotName }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item :label="$t('manuManagement.operator')" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select :placeholder="$t('manuManagement.selectOperator')" showSearch optionFilterProp="children"
                      v-model="queryParam.creator">
                      <a-select-option v-for="(item, index) in userList" :key="index" :value="item.id">
                        {{ item.userName }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item :label="$t('setailManagement.documentStatus')" :labelCol="labelCol"
                    :wrapperCol="wrapperCol">
                    <a-select :placeholder="$t('setailManagement.selectStatus')" v-model="queryParam.status">
                      <a-select-option value="0">{{ $t('manuManagement.notApproved') }}</a-select-option>
                      <a-select-option value="1">{{ $t('manuManagement.reviewed') }}</a-select-option>
                      <a-select-option value="3">{{ $t('manuManagement.partDelivery') }}</a-select-option>
                      <a-select-option value="2">{{ $t('otherJS.completed') }}</a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item :label="$t('setailManagement.notesToDocuments')" :labelCol="labelCol"
                    :wrapperCol="wrapperCol">
                    <a-input :placeholder="$t('setailManagement.pleaseEnterTheNotesOfTheDocument')"
                      v-model="queryParam.remark"></a-input>
                  </a-form-item>
                </a-col>
              </template>
            </a-row>
          </a-form>
        </div>
        <!-- 操作按钮区域 -->
        <div class="table-operator" style="margin-top: 5px">
          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="myHandleAdd" type="primary" icon="plus">{{
              $t('warehouseAllocationManagement.addRequisition')
          }}</a-button>
          <ColumnsSetting @columnsChange="columnsChange" :columns="columns"></ColumnsSetting>
          <a-dropdown>
            <a-menu slot="overlay">
              <a-menu-item key="1" v-if="btnEnableList.indexOf(1) > -1" @click="batchDel"><a-icon type="delete" />{{
                  $t('manuManagement.delete')
              }}</a-menu-item>
              <!-- <a-menu-item key="2" v-if="btnEnableList.indexOf(2)>-1" @click="batchSetStatus(1)"><a-icon type="check"/>{{$t('manuManagement.toExamine')}}</a-menu-item>
              <a-menu-item key="3" v-if="btnEnableList.indexOf(7)>-1" @click="batchSetStatus(0)"><a-icon type="stop"/>{{$t('manuManagement.DeApproval')}}</a-menu-item> -->
            </a-menu>
            <a-button>
              {{ $t('manuManagement.batchOperation') }} <a-icon type="down" />
            </a-button>
          </a-dropdown>
          <a-tooltip placement="left" :title="$t('warehouseAllocationManagement.itInventory')" slot="action">
            <a-icon v-if="btnEnableList.indexOf(1) > -1" type="question-circle" style="font-size:20px;float:right;" />
          </a-tooltip>
          <a-button v-if="btnEnableList.indexOf(3) > -1" :loading="downLoading" style="margin-left: 8px" @click="exportExcel" icon="download">{{$t('reportQuery.export')}}</a-button>
          <a-button v-if="btnEnableList.indexOf(5) > -1"  style="margin-left: 8px" v-print="'#reportPrint'" icon="printer">{{$t('reportQuery.print')}}</a-button>
          <a-button v-if="btnEnableList.indexOf(5) > -1"  style="margin-left: 8px" @click="generatePrintData" icon="printer">{{$t('inPrint.other') + $t('reportQuery.print')}}</a-button>
        </div>
        <!-- table区域-begin -->
        <section ref="print" id="reportPrint">
          <a-table :customRow="rowClick" ref="table" size="middle" bordered rowKey="id" :columns="columns"
            :dataSource="dataSource" :pagination="ipagination" :scroll="scroll" :loading="loading"
            :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }" @change="handleTableChange">
            <span slot="action" slot-scope="text, record">
              <!-- <a @click="myHandleDetail(record, '要货申请单')">{{$t('manuManagement.check')}}</a> -->
              <!-- <a-divider v-if="btnEnableList.indexOf(1) > -1" type="vertical" /> -->
                <a-popconfirm :ok-text="$t('popup.determine')" :cancel-text="$t('inPrint.cancel')" v-if="btnEnableList.indexOf(7)>-1 && record.status !== '0'" :title="$t('popup.confirmReverseAudit')" @confirm="() => myHandleReverseAudit(record)">
                <a type="link">
                  {{$t('manuManagement.DeApproval')}}
                </a>
              </a-popconfirm>
              <a v-if="btnEnableList.indexOf(7)>-1 && record.status === '0'" type="link" :disabled="record.status === '0'">{{$t('manuManagement.DeApproval')}}</a>
              <a-divider v-if="btnEnableList.indexOf(7) > -1" type="vertical" />
              <a v-if="btnEnableList.indexOf(1) > -1" @click="myHandleEdit(record)">{{ $t('manuManagement.edit') }}</a>
              <!-- <a-divider v-if="btnEnableList.indexOf(1) > -1" type="vertical" />
              <a v-if="btnEnableList.indexOf(1) > -1" @click="myHandleCopyAdd(record)">{{ $t('manuManagement.copy')
              }}</a> -->
              <a-divider v-if="btnEnableList.indexOf(1) > -1" type="vertical" />
              <a-popconfirm v-if="btnEnableList.indexOf(1) > -1" :title="$t('manuManagement.areDelete')"
                @confirm="() => myHandleDelete(record)">
                <a>{{ $t('manuManagement.delete') }}</a>
              </a-popconfirm>
            </span>
            <template slot="customRenderStatus" slot-scope="status">
              <a-tag v-if="status == '0'" color="red">{{ $t('manuManagement.notApproved') }}</a-tag>
              <a-tag v-if="status == '1'" color="green">{{ $t('manuManagement.reviewed') }}</a-tag>
              <a-tag v-if="status == '3'" color="blue">{{ $t('manuManagement.partDelivery') }}</a-tag>
              <a-tag v-if="status == '2'" color="cyan">{{ $t('otherJS.completed') }}</a-tag>
              
            </template>
          </a-table>
        </section>
        <!-- table区域-end -->
        <!-- 表单区域 -->
        <allocation-out-modal ref="modalForm" @ok="modalFormOk"></allocation-out-modal>
        <bill-detail ref="modalDetail"></bill-detail>
      </a-card>
    </a-col>
  </a-row>
</template>
<!--power by jishenghua-->
<script>
import AllocationOutModal from './modules/AllocationOutModal'
import BillDetail from './dialog/BillDetail'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import { BillListMixin } from './mixins/BillListMixin'
import JDate from '@/components/jeecg/JDate'
import Vue from 'vue'
export default {
  name: "AllocationOutList",
  mixins: [JeecgListMixin, BillListMixin],
  components: {
    AllocationOutModal,
    BillDetail,
    JDate
  },
  data() {
    return {
      // 查询条件
      queryParam: {
        number: "",
        materialParam: "",
        type: "其它",
        subType: "要货申请",
        roleType: Vue.ls.get('roleType'),
        depotId: "",
        creator: "",
        status: "",
        remark: "",
        depotStatus:3
      },
      labelCol: {
        span: 5
      },
      wrapperCol: {
        span: 18,
        offset: 1
      },
      // 表头
      columns: [
        {
          title: this.$t('manuManagement.documentNo'), dataIndex: 'number', width: 160,
          customRender: function (text, record, index) {
            if (record.linkNumber) {
              return text + "[转]";
            } else {
              return text;
            }
          }
        },
        {
          title: this.$t('manuManagement.productInformation'), dataIndex: 'materialsList', width: 220, ellipsis: true,
          customRender: function (text, record, index) {
            if (text) {
              return text.replace(",", "，");
            }
          }
        },
        { title: this.$t('manuManagement.documentDate'), dataIndex: 'operTimeStr', width: 145 },
        { title: this.$t('manuManagement.operator'), dataIndex: 'loginName', width: 80, ellipsis: true },
        { title: this.$t('manuManagement.totalAmount'), dataIndex: 'totalPrice', width: 80 },
        {
          title: this.$t('manuManagement.state'), dataIndex: 'status', width: 80, align: "center",
          scopedSlots: { customRender: 'customRenderStatus' }
        },
        {
          title: this.$t('manuManagement.operation'),
          dataIndex: 'action',
          align: "center", width: 150,
          scopedSlots: { customRender: 'action' },
        }
      ],
      url: {
        list: "/depotHead/AllotList",
        delete: "/depotHead/delete",
        deleteBatch: "/depotHead/deleteBatch",
        deApprovalUrl:'/depotHead/batchCounterAuditStatus',
        batchSetStatusUrl: "/depotHead/batchSetStatus"
      }
    }
  },
  computed: {
  },
  created() {
    this.getDepotData()
    this.initUser()
  },
  methods: {
    rowClick(record, index) {
      return {
        on: {
          click: () => {
          },
          dblclick: () => {
            console.log('双击了我')
            this.myHandleDetail(record, '要货申请')
          },
        }
      }
    },
  }
}
</script>
<style scoped>
@import '~@assets/less/common.less'
</style>